<template>
  <el-dialog title="选择箱起商品" :visible.sync="dialogVisible" :close-on-click-modal="false">
    <div class="content" @click.stop="()=>{}">
      <el-form label-position="left" label-width="100px" style="width: 100%; padding-left: 20px;">
        <el-form-item label="所选商品：" >
          <div class="el-tag-box">
              <el-tag v-for="(item, index) of result" :key="item.id" :closable="true" @close="delItem(index)">{{item.name}}</el-tag>
          </div>
        </el-form-item>
      </el-form>
      <el-form ref="searchForm" class="search-block" :model="listQuery" label-position="right" label-width="100px" style="width: 100%">
        <el-row>
          <el-col :md="24" :lg="12" :xl="8">
            <el-form-item label="商品名称：" prop="name">
              <el-input @keyup.enter.native="search" v-model="listQuery.goodsName" placeholder="商品名称" maxlength="50" clearable></el-input>
            </el-form-item>
          </el-col>
          <el-button type="primary" icon="el-icon-search" plain @click="search" class="ml10">搜索</el-button>
        </el-row>
      </el-form>
      <div class="check-all">
        <label class="input-checkbox" v-if="config.count !== 1">
          <input type="checkbox" :value="checkAll" v-model="checkAll" @change="handleCheckAll"/>
          <span></span>
        </label>
      </div>
      <el-table :data="list" v-loading="listLoading" element-loading-text="给我一点时间" border @row-click="clickRow">
          <el-table-column align="center" width="50">
              <template slot-scope="scope">
                  <label class="input-radio" v-if="config.count === 1">
                      <input type="radio" :value="{id: scope.row.id}" v-model="itemsRadio" @change="(e) => setValue(e.target.checked, scope.row)"/>
                      <span></span>
                  </label>
                  <label class="input-checkbox" v-else>
                      <input type="checkbox" :value="{id: scope.row.id}" v-model="itemsCheck" @change="(e) => setValue(e.target.checked, scope.row)"/>
                      <span></span>
                  </label>
              </template>
          </el-table-column>
          <el-table-column align="center" label="商品名称" prop="name" min-width="110" show-overflow-tooltip></el-table-column>
          <el-table-column align="center" label="董事价" prop="ordinaryPrice" min-width="60"></el-table-column>
          <el-table-column align="center" label="会员价" prop="marketPrice" min-width="60"></el-table-column>
      </el-table>
      <el-pagination
        @current-change="handleCurrentChange"
        :current-page.sync="listQuery.pageNo"
        :page-size="listQuery.pageSize"
        background
        layout="total, prev, pager, next, jumper"
        style="text-align: center"
        :total="listTotal">
      </el-pagination>
    </div>
    <div slot="footer" class="dialog-footer" @click.stop="()=>{}">
      <el-button type="primary" :loading="btnLoading" @click="choose">确定</el-button>
      <el-button @click="close">取消</el-button>
    </div>
  </el-dialog>
</template>
<script>
import treeToArray from '@/components/TreeTable/eval'
export default {
  name: 'choose-goods',
  props: {
    config: { type: Object, default(){ return {} } },
    selected: { type: Array, default(){ return [] } },
  },
  data(){
    return {
      checkAll: false,
      dialogVisible: true,
      btnLoading: false,
      categoryLoading: true,
      // selected:[],
      result: "",
      itemsCheck: [],
      itemsRadio: {},
      merchants: [],
      categoryTree: [],
      //查询条件
      listQuery: {
        pageNo: 1,
        pageSize: 10,
        goodsName:""
      },
      list: [],
      listTotal: 0,
      listLoading: false
    }
  },
  created() {
    this.showTable();
  },
  methods: {
    showTable(){
      this.result=this.selected;
      this.itemsCheck=this.selected.length ? this.selected.map(item => { return { id: item.id }}): [];
      this.itemsRadio=this.selected.length ? {id: this.selected[0].id} : {};
      this.dialogVisible=true;
      this.getList()
    },
    copyObject (obj) {
      let newObj = {}
      if (obj instanceof  Array) {
        newObj = []
      }
      for (let key in obj) {
        let val = obj[key]
        newObj[key] = typeof val === 'object' ? this.copyObject(val) : val;
      }
      return newObj
    },
    handleCheckAll () {
      let temp = this.copyObject(this.list)
      if (this.checkAll) {
        let has=this.itemsCheck.map(x=>x.id);
        let tempResult=this.list.filter(x=>(!has.includes(x.id)));
        this.result = this.result.concat(tempResult);
        this.itemsCheck =this.result.map(item => { return { id: item.id }});
      } else {
        if (this.itemsCheck.length === this.listQuery.pageSize) {
          this.itemsCheck = []
          this.result = []
        } else {
          // 将一个数组中的值从另一个数组剔除
          this.itemsCheck = this.itemsCheck.filter(item => {
            let idList= this.list.map(v => v.id)
            return !idList.includes(item.id)
          })
          this.result = this.result.filter(item => {
            let resultList= this.list.map(v => v.id)
            return !resultList.includes(item.id)
          })
        }
      }
    },
    // 获取列表
    getList () {
      this.listLoading = true;
      this.request({
        no_err:true,
        url: '/bsnl-product/box/goods/get-all-list',
        method: 'get',
        params: this.listQuery
      }).then(({data, totalCount}) => {
        this.list = data
        this.listTotal = totalCount
        this.listLoading = false
        let tempList = this.list.map(item => { return { id: item.id }})
        let index = this.itemsCheck.findIndex((item) => {
          return item.id === tempList[0].id
        })
        if (index >= 0 && tempList.length === this.listQuery.pageSize) {
          this.checkAll = true
        } else {
          this.checkAll = false
        }
      }).catch(err => {
        this.$message.error("请求错误");
        this.list = []
        this.listTotal = 0
        this.listLoading = false
      });
    },
    resetForm (formName) {
      this.$nextTick(() => {
        this.$refs[formName].resetFields()
      })
    },
    // 搜索
    search () {
      this.listQuery.pageNo = 1
      this.getList()
    },
    // 切换分页
    handleCurrentChange (page) {
      this.listQuery.pageNo = page
      this.getList()
    },
    // 选择change
    setValue(checked, row){
      if(checked){
        if(this.config.count ===1 ){
          this.result = [row]
        } else {
          this.result.push({ ...row })
        }
      } else {
        let index = this.itemsCheck.findIndex(item => row.id === item.id);
        this.result.splice(index, 1);
      }
      let len = this.result.length
      // if (len % this.listQuery.pageSize === 0) {
      //   this.checkAll = true
      // } else {
      //   this.checkAll = false
      // }
    },
    // 单击行
    clickRow(row) {
      if (this.config.count === 1) {
        this.itemsRadio = { id: row.id };
        this.result = [row];
      } else {
        let index = this.itemsCheck.findIndex(item => row.id === item.id);
        if (index < 0){
          this.itemsCheck.push({ id: row.id });
          this.result.push({ ...row });
        } else {
          this.itemsCheck.splice(index, 1);
          this.result.splice(index, 1);
        }
      }
      let len = this.itemsCheck.length
      // if (len % this.listQuery.pageSize === 0) {
      //   this.checkAll = true
      // } else {
      //   this.checkAll = false
      // }
    },
    // 通过tag删除
    delItem(index) {
      this.itemsCheck.splice(index, 1);
      this.result.splice(index, 1);
      this.itemsRadio={};
    },
    // 关闭弹窗
    close(){
      this.dialogVisible = false;
      document.body.removeChild(this.$el);
    },
    // 选完，点击确定
    choose(){
      if(this.result.length < 1){
        return this.$message.error('请选择商品');
      }
      if(this.config.count > 0 && this.itemsCheck.length > this.config.count){
        return this.$message.error(`最多选择${this.config.count}个商品`);
      }
      this.$emit('choose', this.result);
      this.close();
    }
  }
}
</script>
<style lang="scss" scoped>
.check-all {
  margin-left: 15px;
  margin-top: 16px;
  position: absolute;
  z-index: 99;
}
.ml10{
  margin-left: 10px;
}
</style>
